## **Cambridge-1 Instruction Set**

Last updated: 22/09/19

## Registers

areg = A Register (4-bit) breg = B Register (4-bit) inreg = Input Register (4-bit) opreg = Operand Register (8-bit) outreg = Output Register (8-bit) pc = Program Counter (8-bit)

## **Operations**

<< bitwise shift || concatenation nop no operation

## **Flags**

cyflag = Carry Flag eqflag = Equal to Zero Flag gzflag = Greater than Zero Flag

| Mnemonic                                                              | Instruction                                                                                                                                            | Operand                                                                                                                                                                                                                                                               | Details                                                                                                                                                                                                                                                                                                                                                                             |
|-----------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ADDC SUBC CLR LDA LDB MVAB MVBA LALN LBUN STM JUNC JUZE JUGZ PFIX IOP | 0 0 0 0<br>0 0 0 1<br>0 0 1 0<br>0 0 1 1<br>0 1 0 0<br>0 1 0 1<br>0 1 1 0<br>0 1 1 1<br>1 0 0 0<br>1 0 1 1<br>1 1 0 0<br>1 1 0 1<br>1 1 1 0<br>1 1 1 1 | not used not used not used immediate immediate immediate not used not used lower addr | areg ← areg + breg + cyflag areg ← areg - breg + cyflag cyflag = 0 areg ← opreg(lower) breg ← opreg(lower) breg ← areg areg ← breg areg ← memory[opreg](lower) breg ← memory[opreg](upper) memory[opreg] ← breg << 4    areg pc ← opreg if (eqflag) then pc ← opreg if (gzflag) then pc ← opreg opreg ← opreg << 4 outreg[a] ← memory[opreg] outreg[b] ← memory[opreg] areg ← inreg |
| HALT                                                                  | 1111                                                                                                                                                   | [ xx11 ]<br>not used                                                                                                                                                                                                                                                  | nop<br>clock = stop                                                                                                                                                                                                                                                                                                                                                                 |